package vaccine.appointment.system.common.interceptor;

import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.HandlerInterceptor;
import vaccine.appointment.system.common.constants.Constants;
import vaccine.appointment.system.common.utils.JWTUtil;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

/**
 * 登录拦截器
 * 用户访问页面需要校验 jwt 令牌的合法性
 */
@Configuration
public class LoginInterceptor implements HandlerInterceptor {
    /**
     * 在请求处理之前进行调用
     * 校验用户的 jwt 令牌的合法性
     */
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        //获取用户的 token
        String token = request.getHeader(Constants.TOKEN);
        //用户不存在令牌或者令牌非法
        if(token == null || JWTUtil.parseJWT(token) == null) {
            response.setStatus(401);
            //用户未登录，拦截
            return true;
        }
        //用户已登录，放行
        return true;
    }
}
